关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭5年前。ImprovethisquestionC#2和VB.Net8引入了一个名为iterators的新功能,旨在使返回枚举数和枚举数变得更容易。然而,迭代器实际上是coroutines的一种有限形式。,并且可以用来做许多与对象集合无关的有用的事情。您在实际代码中看到过哪些迭代器的非标准用法?
我是一名VB.Net开发人员,有点像C#的新手,在查看Iterators和Generators的C#文档时,无法完全理解其用法,我有任何人可以解释(在vb中有洞察力;如果可能的话) 最佳答案 迭代器是一种生成项目序列的简单方法,无需实现IEnumerable/IEnumerator你自己。迭代器是一种返回IEnumerable的方法您可以在foreach循环中枚举。这是一个简单的例子:publicIEnumerableGetNames(){yieldreturn"Joe";yieldreturn"Jack";yieldreturn"
是否可以在实现System.Collections.IEnumerable的迭代器中使用递归?我有一个大致如下声明的树结构:publicclassNode{publicNodeSibling;publicNodeChild;}我想遍历树中的节点。我想做这样的事情(伪代码,我想这不会编译):publicclassNodeIterator:System.Collections.IEnumerable{Nodem_root;publicSystem.Collections.IEnumeratorGetEnumerator(){recursiveYield(m_root);}System.Co
我有一个元素序列。序列只能迭代一次,可以“无限”。获取这样一个序列的头部和尾部的最佳方法是什么?更新:如果我在原始问题中包含一些说明,那就更好了:)头是序列的第一个元素,尾是“其余”。这意味着尾部也是“无限”的。当我说无限时,我的意思是“非常大”和“我不想一次将它全部存储在内存中”。它也可能实际上是无限的,例如传感器数据(但它不是我的情况)。当我说它只能迭代一次时,我的意思是生成序列会占用大量资源,所以我不想再重复一次。它也可能是volatile数据,再次像传感器数据,在下次读取时不会相同(但在我的情况下不是)。 最佳答案 分解IE
我正在编写重构Silverlight程序以使用WCF服务中的部分现有业务逻辑。这样做时,我遇到了Silverlight3中的限制,它只允许对WCF服务进行异步调用,以避免长时间运行或无响应的服务调用阻塞UI线程的情况(SL有一个有趣的队列模型来调用WCF服务在UI线程上)。因此,编写曾经简单明了的内容正变得越来越复杂(请参阅问题末尾的代码示例)。理想情况下,我会使用coroutines为了简化实现,但遗憾的是,C#目前不支持协程作为本地语言工具。但是,C#确实有使用yieldreturn的生成器(迭代器)的概念。句法。我的想法是重新调整yield关键字的用途,以允许我为相同的逻辑构建一
当我尝试这样做时...Item[,]array=newItem[w,h];//TwodimensionalarrayofclassItem,//w,hareunknownatcompiletime.foreach(variteminarray){item=newItem();}...我得到Cannotassignto'item'becauseitisa'foreachiterationvariable'。不过,我还是想这样做。想法是将默认的Item类值分配给现有项目。 最佳答案 好的,既然我们知道了您的目标,而不是您试图实现它的方式
我创建了一个实现通用IQueue接口(interface)的自定义通用队列,该接口(interface)使用System.Collections.Generic命名空间中的通用队列作为私有(private)内部队列。示例已清除不相关的代码。publicinterfaceIQueue{voidEnqueue(TQueueItemqueueItem);TQueueItemDequeue();}publicclassCustomQueue:IQueue{privatereadonlyQueuequeue=newQueue();...publicvoidEnqueue(TQueueItemqu
这是我用来从数据库中获取数据的示例代码:在DAO层上:publicIEnumerableGetDATA(ICommonSearchCriteriaDtocommonSearchCriteriaDto){using(DbContext){DbDataReaderreader=DbContext.GetReader("ABC_PACKAGE.GET_DATA",oracleParams.ToArray(),CommandType.StoredProcedure);while(reader.Read()){yieldreturnreader;}}}在BO层我调用上面的方法如下:ListGri
给定一个具有以下接口(interface)的基类:publicclassBase{publicvirtualIEnumerableGetListOfStuff(){yieldreturn"First";yieldreturn"Second";yieldreturn"Third";}}我想创建一个重写方法的派生类,并添加自己的东西,如下所示:publicclassDerived:Base{publicoverrideIEnumerableGetListOfStuff(){foreach(stringsinbase.GetListOfStuff()){yieldreturns;}yield
以下代码:Listintervals=newList();Listpoints=newList();//Initializationofthetwolists//[...]foreach(varpointinpoints){intervals.RemoveAll(x=>x.Intersects(point));}当列表的大小为~10000时,至少比这快100倍:Listintervals=newList();Listpoints=newList();//Initializationofthetwolists//[...]foreach(varpointinpoints){for(int